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Description 

[0001] This application is based on the Provisional 
Application. Serial No. 60/097.398: filed 08/21/98; also 
having the title "Packet Network Route Selection Meth- 
od And Apparatus Using A Bidding Algorithm." 
[0002] The present Invention relates to the field of da- 
ta packet delivery across a network and. more specifi- 
cally, to a bidding algorithm that solicits bids for routing 
the data packets across the network. 
[0003] The basic practice of exchanging data packets 
over a communication link is generally known In the art. 
However, there is an ongoing discussion in the industry 
for the best way to route packetized data, such as for IP 
telephony or telephone calls, within the border gate- 
ways. The current Border Gateway Protocol (BPG) will 
have difficulty in routing E.1 64 calls among the autono- 
mous systems .(such as ISPs and large organizations), 
primarily because the E.164 address spaces are geo- 
graphically based and separate from the IP address 
spaces. Hence, there is contention among the autono- 
mous systems for routing the E.164 calls. 
[0004] The prior art practice requires the use of long 
and complicated routing tables which list the various 
links necessary to reach the destination. The use of the 
table may incur significant delay in looking for an ad- 
dress entry. The delay may be acceplable for text data, 
but inadequate for voice data over the network. Further, 
on top of this routing table is a complicated policy layer 
that sets the conditions and policies for exchanging the 
data packets between the two destinations, which typi- 
cally introduces further complexity and delay. 
[0005] Additionally, when multiple autonomous sys- 
tems are present, who can provide multiple pathways to 
the destination, there currently is a lack of adequate con- 
tention resolution among the autonomous systems for 
delivering the packets. Accordingly, it is appreciated that 
some means of providing for an open contention resolv- 
ing mechanism at the border gateways would allow for 
competition among the autonomous systems and may 
reduce the delay encountered at the border gateway. 
The present invention describes a contention resolution 
mechanism based on a bidding algorithm for determin- 
ing the most desirable route for the transfer of a data 
packet. 

[0006] The present invention describes a method and 
apparatus for selecting a route to a destination for a data 
packet. A broadcast is initiated for a request for a bid to 
transfer the data packet on a network where there are 
more than one path to the destination. Then, at least 
one bid is received in response to the broadcast, in 
which the bid includes a routing metric associated with 
the transfer of the packet to the destination through a 
particular path. A desired path to the destination Is se- 
lected, based on the received routing metric(s). 
[0007] Figure 1 is a blocl< diagram showing the net- 
work environment in which the present invention is uti- 
lized to seek bids from various border gates distributed 



between autonomous systems in order to determine a 
desired route in sending a data packet to a destination. 
[0008] Figure 2 shows a fomiat of a broadcast in 
which a criteria for requesting a routing metric Included 
5 in the broadcast. 

[0009] Figure 3 illustrates the generation of a table for 
determining which responding bid should win the bid for 
the packet contention. 

[0010] Figure 4 is a schematic diagram showing a 
10 router at a border gate and the implementation of the 
bidding algorithm of the present invention at the border 
gate. 

[0011] Figure 5 is a flow diagram Illustrating a routine 
of the bidding algorithm for the Initiation of the request 
15 for a bid by the requestor sending the data packet. 
[0012] Figure 6 is a flow diagram illustrating a routine 
of the bidding algorithm for the handling of a bid request 
at a border gate, when the request is sent downstream. 
[001 3] Figure 7 is a flow diagram illustrating a routine 
20 of the bidding algorithm for receiving bids sent upstream 
and the selection of the desired route for data packet 
transfer. 

[0014] Referring to Figure 1, a scheme for routing da- 
ta packets by the practice of the present invention is II- 
25 lustrated in reference to a network environment com- 
prised of a plurality of autonomous systems, shown as 
AS1-AS5. The network environment in the illustrated ex- 
ample is the Internet, however, it Is appreciated that the 
invention can be practiced in other environments as well 
30 where data packets are employed. Accordingly, Internet 
Protocol (IP) is utilized by the various autonomous sys- 
tems shown to communicate on the network. The au- 
tonomous systems are not limited to any particular sys- 
tem and includes. Internet Service Providers (ISPs), 
35 wide area networks (WANs), local area networks 
(LANs), companies, common carriers, etc. 
[0015] In the example of Figure 1 , a host (Host A) of 
Company A will send a packet to a destination host 
(Host 8) of Company B. Host A typically would be a com- 
40 puter (such as a Personal Computer (PC)) coupled to 
Company A's private networi< and operated by an em- 
ployee or agent of Company A. Likewise. Host B is a PC 
operated by Company B. In the hypothetical example. 
Host A is placing an E.164 call to Host B, in which IP 
^5 telephony is achieved by the exchange of data packets 
between Host A and Host B. The example below dis- 
cusses the transfer of a data packet, but It is understood 
that data transfer is usually achieved in streaming a plu- 
rality of such packets. Again, it is appreciated that the 
50 amount or type of packet being transferred Is not critical 
to the understanding of the present invention, since the 
invention is applicable to data packets in general. 
[0016] Also. In the hypothetical example, four border 
gates (also referred to as border gateways), BGs, are 
55 shown associated with Company A. These BGs' are 
shown as A1-A4, corresponding to the connections to 
the autonomous systems AS1-AS4. That is. Company 
A has access to four autonomous systems AS1-AS4, 
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each through a border gateway A1-A4, respectively. 
The BGs are known as gates or gateways and generally 
comprised of some type of processing device and rout- 
ing capability. The basic operation of BGs is known in 
the art. Likewise, Company B has access to two auton- 
omous systems ASS and AS4 through corresponding 
border gateways B1 and B2. A fifth autonomous system 
ASS is shown coupled to AS4 through C1 . It is appreci- 
ated that ASS is not connected to neither Company A 
nor Company B by a border gateway. 
[0017] As evident from Figure 1 , there are two sepa- 
rate paths (routes) from Company A to Company B. 
When Host A wants to send a packet to Host B, the data 
packet can travel from Company A by traversing the 
route A3/AS3/B1 or A4/AS4/B2 to reach Company B. In 
the prior art practice, one of the two routes is pre-des- 
ignated for the particular packet transfer based on the 
established policy requirement. In the practice of the 
present invention, an open bidding (and routing) algo- 
rithm is utilized to select one of the two routes. The se- 
lection as to which route (or path) will depend on a metric 
set for the packet transfer and the response (returned 
bid) received. 

[0018] Thus, when the bidding algorithm of the 
present invention is utilized, the bidding algorithm posts 
(broadcasts) a request for a bid from Company A to its 
border gates A1-A4. The request can take many forms, 
but an example of a "request for a bid" broadcast 11 is 
shown in Figure 2. The broadcast 11 is comprised of a 
requester's (sender's) identification (ID) field 12, a des- 
tination ID field 13 and a request metric field 14, which 
is comprised of criteria for obtaining a routing metric field 
14. The request metric field 14 includes information 
about the data packet(s) being sent and criteria for the 
type of routing metric values being sought. In the exam- 
ple and in the practice of the preferred embodiment, two 
types of metric values are typically being sought. One 
value sought is the actual cost of sending the packet(s) 
and the other is the amount of delay in transporting the 
packet(s) to the destination. It is appreciated that other 
items of information can be included within the broad- 
cast 11. 

[001 9] In Figure 1 , when Company A attempts to con- 
tact Company B for sending the packet, it has available 
four neighboring autonomous systems to broadcast the 
request. Accordingly, Company A broadcasts a request 
for a bid to all of its BGs. If the BGs are using the bidding 
algorithm, the information is passed through the respec- 
tive autonomous system to other border gates coupled 
to the autonomous system. Each BG will then further 
broadcast the request. By this method, each connected 
BG will further propagate the broadcast to another au- 
tonomous system at the next level through downstream 
BGs. until the broadcast reaches the last BG which 
serves the destination address. If the BG is not support- 
ing the bidding algorithm, then it transports the data as 
it is done under the prior art practice of using routing 
tables and policy overiays. 



[0020] Once the closest BG to the destination is 
reached, the border gate responds by setting up and 
sending a routing metric back upstream as a bid. The 
metric contains the values associated with the transfer 

5 of the packet at that level. Subsequently, each BG tra- 
versed upstream inserts a value to the requested metric 
by incrementing the values to any downstream metric it 
receives, until the bid metric reaches all the way back 
upstream to the original requester. The originating BG 

10 will receive bids from those routes available for the 
transfer of the packet. The routing metric will contain val- 
ues which the requester can use to select the path. For 
example, since cost and delay values are utilized in the 
preferred embodiment, the requester can choose the 

15 best route as the least costliest path or as the fastest 
path, 

[0021] Thus, in the example shown in Figure 1 , Com- 
pany A broadcasts the request by posting a bid request 

14 to its four BGs, A1-A4. The broadcast states that the 
20 destination is Host B at Company B and the criteria so- 
licits cost and delay information for sending a packet (or 
a stream of packets) to the destination. The cost and 
delay can be for a single packet or for the streaming of 
multiple packets. If the BGs support the algorithm, then 

25 the broadcast is passed downstream to AS1-AS4. For 
AS1 and AS2, the destination Is not within their domain 
and no other border gates are present. Therefore, AS1 
and AS2 cannot provide a route to reach Company B. 
Accordingly, in response to the broadcast, either a no 
30 response or a response in the negative (depending on 
how the program is made to respond) Is sent back to the 
BGs AI and A2. The preference is not to respond at all. 
[0022] However, AS3 and AS4 can further broadcast 
the request downstream to its other peer BGs coupled 
35 to AS3 and AS4. In this instance A3 further broadcasts 
the request to B1. while A4 broadcasts to B2 and CI. 
CI will not respond since the destination is not within its 
domain. B1 and B2 can now identify themselves as clos- 
est to Company A and each will infonm that a connection 
40 to company B is available at B1 and B2. B1 and B2 will 
each respond by submitting a bid metric back upstream 
in reverse order to how the metric request reached 
them. Thus, cost and delay calculations in transferring 
the packet across the AS3 domain are sent upstream to 
45 A3. A3 then passes this information to Company A. 
[0023] A similar routing metric is generated back up- 
stream from the other path through A4, so that Company 
A receives two bid metric responses from the initial 
broadcast. Figure 3 shows a metric entry table (metric 
50 table) 15, generated by the algorithm and which table 

15 tabulates the values received from the returning bid 
metrics. As noted, the table establishes entries for each 
of the border gates. Thus, the A1-A4 entries are listed. 
Since no valid responses were retumed from AI and A2 

55 within a specified time limit (since the destination cannot 
be reached through these routes), there are no delay 
and cost values entered for AI and A2. However, delay 
and cost values were returned from the path through A3 
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and A4. In the example table 15. the cost through ASS 
is shown as $0.02. while through AS4 is $0.01 . Howev- 
er, the delay is less through AS3 when compared to AS4 
(0.2 sec versus 0.4 sec). Thus, table 15 informs the 
originator that the route through A4 is half as costly, but 
the route through A3 is twice as fast. 
[0024] It is appreciated that the BGs between the 
sender and the destination will also generate a metric 
entry table for storing metric value(s) included in the bid 
(s) which are returned from downstream BGs respond- 
ing to the broadcast. It Is also appreciated that If multiple 
autonomous systems are traversed to reach the desti- 
nation, more than one transport value would be gener- 
ated. In that event, the values of one autonomous sys- 
tem will be incremented to values received from other 
systems downstream, so that the Incremented result will 
be sent upstream back towards the original requester 
as a cumulative routing metric. This is shown in the ex- 
ample of Figure 1 with the inclusion of BG D1 (shown in 
dashed-line). 

[0025] If D1 is present, then a connection exists be- 
tween AS2 and ASS, which allows a path to be desig- 
nated from Company A to Company B through BG A2. 
In this instance, A2 will propagate the request broadcast 
to D1 , which in turn propagates it to B1. Once B1 real- 
izes that the destination can be reached, D1 and A3 will 
receive metric values associated with packet transfer 
across AS3. As noted above, A3 provides this informa- 
tion to Company A. D1 however provides this informa- 
tion to A2 across AS2. D1 then calculates its cost and 
delay values associated with AS2 and increments the 
received metric values from B1 (stored in a metric table) 
by the amount of its values. The incremented bid metric 
(representing the costs for transporting the packet 
across both AS3 and AS2) is then sent upstream to A2 
and ultimately as BG A2 entries in the table 15 of Figure 
3. 

[0026] Cleariy. Company A would choose the 
A3/AS3/B1 path over the A2/AS2/D1/AS3/B1 path, 
since both cost and delay would be greater through the 
longer path. The example is shown to illustrate the as- 
pect of the invention in which a multitude of paths can 
exist between the sender and the recipient of the packet. 
Where multiple levels are encountered, each can be so- 
licited for a bid and the returned routing metric compared 
to designate the most desirable route. Furthermore, in 
paths where multiple costs and delay values are 
present, the values can be incremented at appropriate 
levels as the routing metric is sent back upstream to pro- 
vide a cumulative value. 

[0027] When the cumulative routing metric values are 
returned to the requester (Company A in the example), 
the requester has collected information for resolving the 
contention by the BGs. The requester can set the pa- 
rameters for resolving the contention. For example, 
company A can select the least expensive route. This 
approach may be desirable when sending text data 
packets to Company B. However, for telephony commu- 



nication where real time conversation is more critical, 
the path with the least delay may be more attractive. 
Likewise, a compromise equation can be set for obtain- 
ing the most optimum cost/delay factors. The basis for 
5 the best or most desirable route selection is a choice 
available for programming within the algorithm, 
[0028] In those instances where a particular BG re- 
ceives more than one bid, a similar or simpler contention' 
resolving mechanism can be employed to resolve con- 
10 tentions. In that way, a BG receiving multiple down- 
stream bid entries can resolve the contention and sub- 
mit only one bid metric upstream. 
[0029] It is appreciated that there are a number of 
ways to design and implement a routing system support- 
's Ing the bidding algorithm for the practice of the present 
invention. One example system is illustrated in Figure 
4. In Figure 4, a processing device 20 is shown repre- 
senting the controlling device at a border gateway. Gen- 
erally, the processing device 20 is comprised of a proc- 

20 essor, computer, server and/or a router (hence, device 
20 is hereafter referred to simply as router 20). The par- 
ticular example router is that of the device present at the 
border gate A4 of Figure 1 . It is appreciated that the gen- 
eral operation of border gates is known in the art. It is 

25 also appreciated that the BG of Figure 4 is shown as a 
single unit for ease of understanding, but in practice, the 
BG may be a distributed system. Thus, it is to be noted 
that portions of the router 20 may reside at different 
physical locations. 

30 [0030] The router 20 is comprised of a processor 21 . 
The processor 21 Is controlled by a program 22, which 
is typically stored in a storage medium, such as a mem- 
ory component or a magnetic disk. The program 22 in- 
cludes the bidding algorithm for practicing the Invention 

35 as described above. The router will generally include a 
register 22 for receiving the bid request and the same 
or different register 23 for further broadcasting the re- 
quest. The requester ID is now replaced by its own re- 
quester ID since the BG is now soliciting the bid from a 

40 unit downstream. The destination and the criteria for the 
bid need not change and continue to be rebroadcast. 
The program also sets a metric entry table 25, which is 
equivalent to the table 15 of Figure 3 for entering the 
retrieved metric values. The table 25 Is typically set in 

<5 memory for storing the metric values. 

[0031] Thus, in the example, a request for a bid is re- 
ceived by router 20 when broadcast by the requester 
upstream in the chain, which can be the host sender or 
one of the border gates. The router 20. after receiving 

50 the request, processes the request and further broad- 
casts the request since the destination is not within its 
domain. In the example, border gates C1 and B2 receive 
the rebroadcast from A4. A bid metric response is re- 
turned by the valid border gate(s), which is 82 in the 

55 example. C1 would not return a response within the al- 
lotted time limit, so that the router 20 will disregard the 
CI entries in table 25. The retumed cost and delay val- 
ues from B2 are entered in the table 25 (shown as X and 
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Y for B2). If the values need to be incremented, the rout- 
er will generate the cumulative value for sending it up- 
stream back toward the requester. 
[0032] The algorithm present in the program 22 is uti- 
lized to control the router 20 so that it will respond ap- 
propriately with the bid requests and the returning metric 
values. It Is appreciated that the algorithm is generally 
in the form of software or firmware for controlling the 
operation of the processor 21. Again, the device 20 of 
Figure 4 can be distributed at multiple locations, how- 
ever, would function as shown. An example flow chart 
of the algorithm for practicing the invention is shown in 
Figures 5-7 

[0033] In Figure 5, an example bid initiating routine 30 
of the algorithm is shown. A host initiates a request when 
the host has a packet to send to a designated destina- 
tion (shown in block 31 ). The bid request is prepared, in 
which the destination address and criteria associated 
with the packet transfer are included in the request being 
sent to the border gates (shown in block 32). The bid 
request is broadcast to the border gates (shown in block 
33). The host then sets up the comparison table (shown 
in block 34) and waits for the return of the bids in re- 
sponse to the broadcast (shown in block 35). 
[0034] In Figure 6, an example routine 40 utilized with- 
in a border gate for handling a bid request, when the bid 
request is sent downstream, is Illustrated. The BG re- 
ceives the broadcast from an upstream requester 
(whether it be the host or another BG) for processing 
(shown in block 41 ) and checks to determine if the des- 
tination Is not reachable (shown in block 42). If not 
reachable, then it does not respond at all or responds 
in the negative (shown in block 43). Again, the prefer- 
ence is not to respond. If the destination is reachable or 
if the BG is uncertain if it can be reached, then it pro- 
ceeds to the next step (shown in block 44) to determine 
if the destination is within the present domain. If the des- 
tination is not reachable at the present domain, the bid 
request Is propagated to the next level downstream 
(shown in block 45) and the sequence of routine 40 Is 
repeated at the downstream BG. If the destination is 
served by the present BG, then the routing metric is cal- 
culated (shown in block 46) and propagated upstream 
(shown in block 47). 

[0035] When the BG propagates the request down- 
stream, it waits for a response from the downstream de- 
vice. Usually, a time period Is specified for the return of 
a bid once a request is broadcast. If a bid is returned 
within the allotted time, the BG obtains the bid and 
stores the metric values in its metric table for its calcu- 
lation or for propagating it upstream. The steps for send- 
ing a bid upstream is shown in Figure 7. 
[0036] Figure 7 shows a routine 50 when bids are re- 
turned upstream for further upstream propagation or for 
selecting the desired route for transferring the data 
packet. Accordingly, as shown in Figure 7, a BG as- 
sumes that there are downstream devices (if a request 
for a bid was sent downstream) and waits for the return 



response(s). When a bid response is received (shown 
in block 51), the routing metric is obtained (shown in 
block 52). The metric value(s) can be stored in a metric 
table at the border gate, if desired and the algorithm is 

s set up to do so. The returning metric is valid, provided 
the waiting period for the bid has not expired (shown in 
block 53). If the waiting period has expired, any re- 
sponse returning after the wait time lapse is disregard- 
ed. Thus, non-responding BGs and BGs late in returning 

^0 a response are disregarded by the routine after time out 
(shown in block 54). 

[0037] If the waiting time period has not lapsed for the 
retuming bid metric, the response to the bid metric(s) 
obtained will depend on the BG's connection to the orig- 

15 mating host. If the particular BG is not serving the orig- 
inating host (shown in block 55), then its own routing 
metric values are determined (shown in block 56) and 
incremented to the metric obtained from downstream 
(shown in block 57). The Incremented (cumulative) met- 

20 ric is propagated upstream (shown in block 58) and the 
routine 50 is repeated at the next upstream BG. 
[0038] However, if the particular BG is serving the 
originating host (shown in block 55), the metric is col- 
lected in the metric table for the host (shown in block 

25 60). If the table entries are not complete, other metrics 
are sought from other BGs. The table entries are com- 
plete, when ail entries are received or when the wait time 
has lapsed (shown in block 61). If multiple valid table 
entries are present, the algorithm uses a particular de- 

30 cision-making parameter based on the received metric 
values for selecting the most desirable path. The desir- 
able route is selected (shown in block 62). followed by 
the sanding of the data packet or packets through the 
selected route (shown in block 63). 

35 [0039] It is appreciated that some of the steps shown 
in the routine can be performed in parallel with other 
steps. Furthermore, when a border gate receives more 
than one bid from downstream BGs, a similar decision- 
making process can be implemented at the BG for se- 

40 lecting one bid for upstream propagation. The appropri- 
ate bid response selected can be based on the defined 
packet criteria being sent downstream and/or the criteria 
established by the host. Accordingly, the particular BG 
can collect multiple entries in its table, determine which 

45 downstream path is most desirable, increment its rout- 
ing metric values to the one selected downstream path 
and send the cumulative metric upstream. 
[0040] Thus, the practice of the present invention al- 
lows a host to post a request for a bid for delivering the 

50 packet to a particular destination and in which certain 
criteria associated with the packet is also included in the 
posting. The bidding request is propagated downstream 
toward the destination, in which the propagation path 
may take more than one route. When the closest BG to 

55 the destination is reached for each path that can support 
the bidding algorithm, the routing metric responses to. 
the solicited packet criteria are propagated in reverse 
back upstream. Each BG along the path increments to 
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than one path to the destination; 
receiving at least one bid in response to the 
broadcast request, the bid including a routing 
metric associated with the transfer of the packet 
5 to the destination through a particular path; 

selecting a desired path to the destination 
based on the received routing metric. 

2. The method of claim 1 wherein the receiving of the 
to routing metric includes a cost value which specifies 

a cost of transporting the packet to the destination. 

3. The method of claim 1 or 2 wherein the receiving of 
the routing metric includes a delay value which 

15 specifies a time duration required for transporting 
the packet to the destination. 

4. The method of any preceding claim wherein the re- 
ceiving of the routing metric includes a cost value 

20 which specifies a cost of transporting the packet to 
the destination and a delay value which specifies a 
time duration required for transporting the packet to 
the destination, and the selecting of the desired 
path is based on the cost and delay values for a type 

25 of data packet being transferred. 

5. The method of any preceding claim wherein the. 
broadcasting of the request for the bid is for trans- 
ferring a plurality of packets. 

30 

6. The method of any preceding claim further compris- 
es the resolving of a contention for the packet when 
more than one bid is received, wherein the received 
routing metrics are analyzed based on established 

35 parameters for the selecting of a winning bid for the 
desired path to the destination. 

7. The method of any preceding claim wherein the net- 
work comprises multiple paths to the destination 

40 through multiple systems on the network for trans- 
porting the packet. 

8. The method of claim 7 further comprising receiving 
a plurality of bids in response to the broadcast re- 

45 quest. 

9. The method of claim 7 or 8 further comprising the 
step of analyzing the received routing metric using 
established routing parameters. 

50 

10. The method of any one of claims 7 to 9 further com- 
prises the resolving of a contention for the packet 
by multiple bids, wherein the analyzing of the re- 
ceived routing metrics is based on the type of data 

55 packet being transferred. 



the metric to reflect its portion of the path and the final 
cumulative metric is returned to the original requester of 
the bids. When multiple bids are returned, the host can 
collect and utilize the returned metric to set parameters 
for selecting the most desirable path for sending the da- 
ta packet{s). The BG can also discriminate between the 
bids it receives from downstream. 
[0041] In the preferred embodiment, cost and delay 
values are included within the routing metric. The cost 
value is the cost in monetary terms (dollars, for example) 
in sending the packet, while delay is measured In terms 
of time (for example, seconds). Thus, the host can de- 
termine which path provides the most cost savings or 
which path provides the least delay, in order to select 
one winning bid as the desired path. This choice allows 
distinguishing the most effective path for a given type of 
data being sent across the network. For example, text 
data can be sent by the less costly path, while telephony 
may opt for the path with the least delay. 
[0042] It Is appreciated that the type of metric being 
returned need not rely on cost or delay only. Other metric 
values can be ready sought. For example, cost can be 
termed in variation from a standard set rate (instead of 
actual dollars cost). Other metric values may address 
bandwidth across the path, so that paths with low band- 
width properties could be bypassed. Thus, the invention 
can be readily practiced utilizing a variety of different 
metrics. 

[0043] Furthemiore, the invention can be practiced in 
the sending of single packets, multiple packets, as well 
as the streaming of multiple packets. The invention was 
described in reference to networks utilizing the Internet 
Protocol across the Internet, however, the Invention can 
be practiced on other networks as well. Therefore, the 
packet network can include IP, ATM (Asynchronous 
Transfer Mode), LANs, WANs. ETHERNET and SONET 
(Synchronous Optical Network). 
[0044] Thus, a packet network route selection method 
and apparatus using a bidding algorithm is described. It 
is also appreciated that the bidding algorithm of the 
present invention can readily replace existing algo- 
rithms, such as the prior art algorithrh utilized in current 
BGPs, in order to allow existing devices to practice the 
present invention. The present invention provides for an 
open martlet packet exchange, allowing for a competi- 
tive environment for packet exchange, as well as a vir- 
tual exchange, where Individual autonomous systems 
can obtain the capability to transport packets once con- 
nected to the network. 



Claims 

1 . A method of selecting a route to a destination for a 
data packet comprising: 

broadcasting a request for a bid to transfer the 
data packet on a network where there are more 



1 1 . The method of any preceding claim wherein the net- 
work is a member of the group consisting of IP, ATM. 
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ETHERNET and SONET 

12. A method of submitting a bid by a border gate on a 
network for routing of a data packet through the bor- 
der gate to a destination comprising: 

receiving a request for a bid to transfer the data 
packet through a path which includes the bor- 
der gate; 

determining a routing metric associated with 
the transfer of the packet to the destination 
through the border gate; 
submitting a bid which includes the routing met- 
ric to a sender of the request for a bid. 

13. The method of claim 12 wherein the determining of 
the routing metric includes a cost value which spec- 
ifies a cost of transporting the packet to the desti- 
nation. 

14. The method of claim 1 2 or claim 1 3 wherein the de- 
termining of the routing metric includes a delay val- 
ue which specifies a time duration required for 
transporting the packet to the destination. 

1 5. The method of claims 1 2, 1 3 or 1 4 further comprises 
the incrementing of the routing metric to a down- 
stream routing metric received from a downstream 
border gate before submitting the bid upstream. 

16. A method of submitting a bid by a border gate on a 
network for routing of a data packet through the bor- 
der gate to a destination comprising: 

receiving a request for a bid from a requester 
upstream to transfer the data packet through a 
path which includes the border gate; 
rebroadcasting the request for a bid down- 
stream towards the destination If another bor- 
der gate resides in the path prior to reaching 
the destination; 

determining a routing metric associated with 
the transfer of the packet from upstream to the 
border gate; 

receiving a downstream bid, which includes a 
downstream routing metric, from a downstream 
gateway; 

incrementing the routing metric to the down- 
stream routing metric received; 
submitting a bid based on the routing metric or 
a cumulative of the routing metric and the 
downstream routing metric to an upstream 
sender of the request for the bid. 

17. The method of claim 16 wherein the determining of 
the routing metric and the downstream routing met- 
ric if there Is one, includes a cost value which spec- 
ifies a cost of transporting the packet to the desti- 



nation. 

18. The method of claim 16 or claim 17 wherein the de- 
termining of the routing metric and the downstream 

5 routing metric If there Is one. includes a delay value 
which specifies a time duration required for trans- 
porting the packet to the destination. 

19. The method of claims 16, 17, or 18 wherein the re- 
10 celving of the request for the bid is for transferring 

a plurality of packets. 

20. A machine readable medium having resident ther- 
eon programmed instructions for selecting a route 

15 to a destination for a data packet on a network, the 

instructions when executed by a processor, causes 
the processor to perform the steps of any one of 
claims 1 to 19. 

20 21 . An apparatus for selecting a route to a destination 
for a data packet comprising: 

a processor: 

a table in memory for storing a metric value, 
25 said memory coupled to said processor; 

said processor broadcasting a request for a bid 
to transfer the data packet on a network where 
there are more than one path to the destination 
and receiving at least one bid in response to 
30 the broadcast request, the bid including the 

routing metric associated with the transfer of 
the packet to the destination through a particu- 
lar path, in which the routing metric is stored In 
said table; 

^5 said processor selecting a desired path to the 

destination based on the received routing met- 
ric. 

22. The apparatus of claim 21 wherein said processor 
^0 receives a downstream routing metric from a down- 
stream border gate and stores the downstream 
routing metric in said table; 

said processor increments Its routing metric 
to the stored downstream routing metric and sub- 
^5 mits an Incremented result as a bid upstream to a 
sender of the request for a bid. 

23. The apparatus of claim 21 or claim 22 wherein the 
routing metric includes a cost value which specifies 

50 a cost of transporting the packet to the destination. 

24. The apparatus of claim 21 or claim 22 wherein the 
routing metric includes a delay value which speci- 
fies a time duration required for transporting the 

55 packet to the destination . 

25. The apparatus of claims 21 to 24 wherein said proc- 
essor further resolves a contention for the packet 
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when more than one bid is received, wherein the 
received routing metrics are analyzed based on es- 
tablished parameters in order for said processor to 
select a winning bid for the desired path to the des- 
tination. 5 

26. The apparatus of claims 21 to 25 in which the sub- 
mitted bid is in response to a request for transferring 
a plurality of packets. 

10 

27. A border gate for submitting a bid on a network for 
routing of a data packet to a destination comprising 
the apparatus of any one of claims 21 to 26. 

15 
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